---
title: queryField
codeStyle: true
---

## queryField

Often times you want to split up query fields into different domains of your application, and like [`mutationField`](/api/mutation-field) are another one of the most common use-cases for `extendType`. `queryField` exists as a shorthand for this common case:

```ts
import { stringArg } from 'nexus'

export const usersQueryField = queryField('user', {
  type: SomeType,
  args: {
    id: nonNull(stringArg()),
  },
  resolve() {
    // ...
  },
})
```

as shorthand for:

```ts
export const usersQueryField = extendType({
  type: 'Query',
  definition(t) {
    t.field('user', {
      type: SomeType,
      args: {
        id: nonNull(stringArg()),
      },
      resolve() {
        // ...
      },
    })
  },
})
```

You can also use it with a function as the first argument, which will pass the `t` provided to the definition block, especially useful when using with the [connection plugin](/plugins/connection):

```ts
export const usersQueryField = queryField(t => {
  t.connectionField('users', {
    type: SomeType,
    resolve() {
      // ...
    },
  })
})
```
